<!DOCTYPE html>
<html lang="zh-CN"
      xmlns="http://www.w3.org/1999/xhtml"
      xmlns:th="http://www.thymeleaf.org"
      xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
      xmlns:shiro="http://www.pollix.at/thymeleaf/shiro"
      layout:decorator="model/boardModel">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>

    <title>员工列表</title>

</head>
<body>

<div th:fragment="pagenav" th:remove="tag">
    <div th:replace="model/nav :: pageheader ('门店管理','员工管理')"></div>
</div>

<div th:fragment="content" th:remove="tag">


    <div class="row">
        <div class="col-xs-12">

            <div class="box box-primary">
                <div class="box-header with-border">
                    <h3 class="box-title">查询条件</h3>
                    <div class="box-tools pull-right">
                        <button class="btn btn-box-tool" data-widget="collapse"><i class="fa fa-minus"></i></button>
                    </div>
                </div>
                <!-- /.box-header -->
                <!-- form start -->
                <form role="form" id="queryForm" th:action="@{/emp/list}" method="post" >
                    <div class="box-body">
                        <div class="row">
                            <input type="hidden" th:name="status" id="status" th:value="1"/>
                            <div class="col-xs-3">
                                <input type="text" th:name="empName" class="form-control input-sm" placeholder="姓名"/>
                            </div>
                            <div class="col-xs-3">
                                <input type="text" th:name="phone" class="form-control input-sm" placeholder="电话"/>
                            </div>
                            <div class="col-xs-3">
                                <select name="status" class="form-control select2" >
                                    <option value="1">待审核</option>
                                    <option value="2">已审核</option>
                                </select>
                            </div>
                            <shiro:hasRole name="sys_supervisor">
                                <input type="hidden" th:name="supervisorId" th:value="${session.authUser.userId}"/>
                            </shiro:hasRole>
                            <div class="col-xs-3">
                                <button id="btn-query" type="button" class="btn btn-primary pull-right btn-sm">查询</button>
                            </div>
                        </div>
                    </div>
                    <!-- /.box-body -->

                    <div class="box-footer">

                    </div>
                </form>
            </div>


            <div class="box">

                <!-- /.box-header -->
                <div class="box-body">
                    <div class="table-responsive">
                    <table id="dataTable" class="table table-striped table-bordered table-hover table-condensed">

                        <thead >
                        <tr>
                            <th>选择</th>
                            <th>账户</th>
                            <th>姓名</th>
                            <th>职务</th>
                            <th>电话</th>
                            <th>状态</th>
                            <th>创建时间</th>
                            <th>操作</th>
                        </tr>
                        </thead>
                    </table>
                    </div>
                </div>
                <!-- /.box-body -->
            </div>
            <!-- /.box -->
        </div>
    </div>

    <div class="modal fade" id="editModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
        <div class="modal-dialog">
            <div class="modal-content">

                <div class="modal-header" style="background-color: #307095;">
                    <button type="button" class="close" data-dismiss="modal" id="btn_close" >
                        <span aria-hidden="true">&times;</span><span class="sr-only">关闭</span>
                    </button>
                    <h4 class="modal-title" id="myModalLabel2">员工-审核</h4>
                </div>

                <div class="modal-body">
                    <form class="form-horizontal"  id="editForm"  method="post">
                        <input type="hidden" class="form-control" name="empId"/>
                        <div class="form-group">
                            <label  class="col-sm-3 control-label">用户名</label>
                            <div class="col-sm-9">
                                <input type="text" class="form-control" name="loginName" readonly="readonly"
                                       />
                            </div>
                        </div>
                        <div class="form-group">
                            <label class="col-sm-3 control-label">姓名</label>
                            <div class="col-sm-9">
                                <input type="text" class="form-control" name="empName" readonly="readonly" placeholder="姓名"
                                       />
                            </div>
                        </div>
                        <div class="form-group">
                            <label class="col-sm-3 control-label">所属门店</label>
                            <div class="col-sm-9">
                                <select class="form-control select2" disabled="disabled" name="storeId" id="inputStoreId" data-rule-required="true" data-msg-required="请选择所属门店">
                                </select>
                            </div>
                        </div>
                        <div class="form-group">
                            <label  class="col-sm-3 control-label">职务</label>
                            <div class="col-sm-9">
                                <select class="form-control select2" name="empType" disabled="disabled"  data-rule-required="true" data-msg-required="请选择职务">
                                    <option value="" >请选择</option>
                                    <option value="1">店员</option>
                                    <option value="2">审核人</option>
                                </select>
                            </div>
                        </div>
                        <div class="form-group">
                            <label  class="col-sm-3 control-label">联系电话</label>
                            <div class="col-sm-9">
                                <input type="text" class="form-control" name="phone" readonly="readonly"  placeholder="联系电话"
                                       />
                            </div>
                        </div>
                        <div class="form-group">
                            <label  class="col-sm-3 control-label">邮箱</label>
                            <div class="col-sm-9">
                                <input class="form-control" name="email" rows="3" placeholder="邮箱" readonly="readonly"
                                      />
                            </div>
                        </div>
                        <div class="form-group">
                            <label  class="col-sm-3 control-label">审核状态</label>
                            <div class="col-sm-9">
                                <select class="form-control select2" name="status" id="inputStatus"  data-rule-required="true" data-msg-required="请选择状态">
                                    <option value="">请选择</option>
                                    <option value="2">审核通过（启用）</option>
                                    <option value="4">审核不通过</option>
                                    <option value="3">审核通过（设为测试账号）</option>
                                </select>
                            </div>
                        </div>
                        <div class="form-group">
                            <label class="col-sm-3 control-label">佣金比例</label>
                            <div class="col-sm-9">
                                <input type="text" class="form-control" name="rate"  readonly="readonly"
                                      />
                            </div>
                        </div>
                        <div class="form-group">
                            <div class="col-sm-9">
                            <span><code><strong>注：</strong>请核实店员信息，确认无误后选择对应的审核状态。</code></span>
                            </div>
                            </div>
                    </form>
                </div>
                <div class="modal-footer">
                    <button type="submit" id="btn-submit" class="btn btn-primary">提交</button>
                </div>
            </div>
        </div>
    </div>
    <!-- DataTables -->
    <script>

        $(function (){
            var tables = $("#dataTable").dataTable({
                serverSide: true,//分页，取数据等等的都放到服务端去
                processing: true,//载入数据的时候是否显示“载入中”
                pageLength: 10,  //首次加载的数据条数
                ordering: false,//排序操作在服务端进行，所以可以关了。
                /*pagingType: "full_numbers",*/
                autoWidth: false,
                stateSave: true,//保持翻页状态，和tables.fnDraw(false);结合使用
                searching: false,
                ajax: {   //类似jquery的ajax参数，基本都可以用。
                    type: "post",//后台指定了方式，默认get，外加datatable默认构造的参数很长，有可能超过get的最大长度。
                    url: "/emp/list",
                    dataSrc: "data",//默认data，也可以写其他的，格式化table的时候取里面的数据
                    data: function (d) {//d是原始的发送给服务器的数据，默认很长。
                        var param = {}; //因为服务端排序，可以新建一个参数对象
                        param.draw = d.draw;
                        param.start = d.start;
                        param.length = d.length;
                        var formData = $("#queryForm").serializeArray();//把form里面的数据序列化成数组
                        formData.forEach(function (e) {
                            param[e.name] = e.value;
                        });
                        return param;//自定义需要传递的参数。
                    }
                },
                columns: [//对应上面thead里面的序列
                    {"data": 'empId',
                        "render":function (data,type,full,callback) {
                            return /*<![CDATA[*/"<input type='checkbox' name='check' value='"+data+"'/>"/*]]>*/;
                        }
                    },
                    {"data": 'loginName'},
                    {"data": 'empName'}, //mData 表示发请求时候本列的列明，返回的数据中相同下标名字的数据会填充到这一列
                    {"data": 'empType',
                        "render":function (data,type,full,callback) {
                            if(data=='1')
                                return /*<![CDATA[*/"<span class='label label-success'>店员</span>"/*]]>*/;
                            else return /*<![CDATA[*/"<span class='label label-success'>审核人</span>"/*]]>*/;
                        }
                    },
                    {"data": 'phone'},
                    {"data": 'status',
                        "render":function(data,type,full,callback) {
                            if(data=='1')
                                return /*<![CDATA[*/"<span class='label label-primary'>待审核</span>"/*]]>*/;
                            if(data=="0") return /*<![CDATA[*/"<span class='label label-danger'>禁用</span>"/*]]>*/;
                            if(data=="2" || data=="3") return /*<![CDATA[*/"<span class='label label-success'>启用</span>"/*]]>*/;
                            if(data=="4") return /*<![CDATA[*/"<span class='label label-danger'>审核未通过</span>"/*]]>*/;
                        }
                    },
                    {"data": 'createTimeStr', defaultContent: ""},
                    {"data": null,"width":"120px"}

                ],

                /*<![CDATA[*/
                columnDefs: [
                    {
                        targets: -1,//编辑
                        data: null,//下面这行，添加了编辑按钮和，删除按钮
                        defaultContent: "<div class='btn-group'><button id='editRow' class='btn btn-primary btn-sm' type='button'><i class='fa fa-edit'></i>审核</button></div>"
                    }
                ],
                dom: '<"toolbar">frtip',
                /*]]>*/

                //每加载完一行的回调函数
                createdRow: function( row, data, index ) {
                    //修改单元格样式
                    //$('td', row).eq(5).css('font-weight',"bold").css("color","red");//获取到具体行具体格的元素
                },
                initComplete: function (setting, json) {
                    //初始化完成之后替换原先的搜索框。
                },
                //在每次table被draw完后调用
                /*fnDrawCallback: function(){
                 var api = this.api();
                 //获取到本页开始的条数
                 var startIndex= api.context[0]._iDisplayStart;
                 api.column(0).nodes().each(function(cell, i) {
                 cell.innerHTML = startIndex + i + 1;
                 });
                 },*/


                language: {
                    lengthMenu: "",//不显示记录条数选择
                    //lengthMenu: '<select class="form-control input-xsmall">' + '<option value="5">5</option>' + '<option value="10">10</option>' + '<option value="20">20</option>' + '<option value="30">30</option>' + '<option value="40">40</option>' + '<option value="50">50</option>' + '</select>条记录',//左上角的分页大小显示。
                    processing: "加载中",//处理页面数据的时候的显示
                    /*<![CDATA[*/
                    paginate: {//分页
                        // 的样式文本内容。
                        previous: "<",
                        next: ">",
                        first: "<<",
                        last: ">>"
                    },
                    /*]]>*/
                    zeroRecords: "没有数据",//table tbody内容为空时，tbody的内容。
                    //下面三者构成了总体的左下角的内容。
                    //info: "共 _PAGES_ 页，显示第 _START_ 到第 _END_ 条 ",//筛选之后得到 _TOTAL_ 条，初始 _MAX_ 条   左下角的信息显示，大写的词为关键字。
                    info: "共 _PAGES_ 页，显示第 _START_ 到第 _END_ 条",
                    infoEmpty: "0条记录",//筛选为空时左下角的显示。0条记录
                    infoFiltered: "",//筛选之后的左下角筛选提示(另一个是分页信息显示，在上面的info中已经设置，所以可以不显示)，
                    sSearch: "关键字："
                }

            });
            /*<![CDATA[*/
            $("div.toolbar").html('<button type="button" class="btn btn-primary btn-sm" id="btn-add">一键审核</button>');
            /*]]>*/
            //查询按钮
            $("#btn-query").on("click", function () {
                tables.fnDraw();
            });
            $("#btn-add").click(function () {
                var ids = new Array();
                var flag = true;
                $("#dataTable input[name=check]:checked").each(function () {
                    ids.push($(this).val())
                    var data = tables.api().row($(this).parents("tr")).data();
                    if(data.status!=1){
                        flag = false;
                    }
                })
                if(!flag){
                    toastr.error("请选择未审核的店员");
                    tables.fnDraw();
                    return;
                }
                if(ids.length>0){
                    var idstr=ids.join(',');
                    $("#btn-add").attr("disabled",true);
                    $.ajax({
                        url:'/emp/auditEmpList',
                        type:'POST',
                        data:{"ids":idstr},
                        dataType: "json",
                        cache: "false",
                        success:function(result){
                            if(result.result==200 ){
                                toastr.success(result.msg);
                                $("#btn-add").attr("disabled",false);
                                tables.fnDraw();
                            }
                        },
                        error:function(err){
                            $("#btn-add").attr("disabled",false);
                            toastr.error("网络错误...");
                        }
                    });
                }else {
                    toastr.error("请选择要审核的店员");
                }

            })

            $("#btn_close").click(function () {
                $("#editModal").css('display','none');
                $("#forPassword > label").show();
                $("#password").attr("type","password");
                $("#inputStoreId > option").remove();
            })
            //修改
            $("#dataTable tbody").on("click", "#editRow", function () {

                var data = tables.api().row($(this).parents("tr")).data();
                if(data.status==1){
                    $("#forPassword > label").hide();
                    $("#password").attr("type","hidden");
                    var kaId ;
                    if($("#kaId").val()){
                        kaId = $("#kaId").val();
                    }else{
                        kaId = data.kaId;
                    }
                    $.ajax({
                        url:'/emp/getStoreList',
                        type:'POST',
                        data:{"kaId":kaId},
                        dataType: "json",
                        cache: "false",
                        success:function(result){
                            if(result.result==200 ){
                                if(data.storeId==null){
                                    /*<![CDATA[*/
                                    $("#inputStoreId").append("<option value='' ></option>");
                                    /*]]>*/
                                }
                                $.each(result.data,function(i,n){
                                    /*<![CDATA[*/
                                    if(n.storeId==data.storeId){
                                        $("#inputStoreId").append("<option value='"+n.storeId+"' selected='selected'>"+n.storeName+"</option>");
                                    }else {
                                        $("#inputStoreId").append("<option value='" + n.storeId + "' >" + n.storeName + "</option>");
                                    }
                                    /*]]>*/
                                });
                            }
                        },
                        error:function(err){
                            toastr.error("网络错误...");
                        }
                    });
                    $("#editModal input[name=empId]").val(data.empId);
                    $("#editModal input[name=loginName]").val(data.loginName);
                    $("#editModal input[name=empName]").val(data.empName);
                    $("#editModal select[name=empType]").val(data.empType);
                    $("#editModal input[name=phone]").val(data.phone);
                    $("#editModal input[name=email]").val(data.email);
                    $("#editModal select[name=status]").val("");
                    $("#editModal input[name=rate]").val(data.rate);

                    $("#editModal").modal("show");
                }else{
                    toastr.error("改店员已审核完成")
                }
            });
            //添加、修改  表单异步提交
            $("#btn-submit").on("click", function(){
                if($("#editModal select[name=status]").val()) {
                    $("#btn-submit").attr("disabled",true);
                    var empId = $("#editModal input[name=empId]").val();
                    var status = $("#editModal select[name=status]").val();
                    $.ajax({
                        cache: false,
                        type: "POST",
                        url: "/emp/auditEmp",
                        data: {"empId":empId,"status":status},
                        dataType: "json",
                        async: false,
                        error: function (request) {
                            toastr.error("网络错误...");
                        },
                        success: function (data) {
                            if (data.result == "200") {
                                $("#btn-submit").attr("disabled",false);
                                $("#editModal").modal("hide");
                                bootbox.confirm(
                                    {
                                        message: data.msg,
                                        buttons: {
                                            confirm: {
                                                label: '确认'
                                            }
                                        },
                                        callback: function (result) {
                                            tables.fnDraw();
                                            // toastr.success(data.msg);
                                            $("#inputStoreId > option").remove();
                                        }
                                    });
                            } else {
                                toastr.error(data.msg);
                            }
                        }
                    });
                }else{
                    toastr.error("请选择员工的审核状态！");
                }
            });

        })



    </script>


</div>
</body>
</html>